

# Fake Currency Detector

Digital Systems (ES 203) Project Harsh Patel - Dhruvin Patel - Harish Meghwal - Abhinav Singh - Jitender Kumar

## **ABSTRACT**

With technological advancements increasing day by day, the misuse of this technology has also escalated, leading to a nuisance to the public and citizens. One such example of crimes is printing and using the fake currency. This is a loss not only for the individual who is duped but also for the country's economy as a whole. To curb this crime, we have designed a fake currency note detector, implemented on the **Field Programmable Gate Array (FPGA)**.

## BACKGROUND

Every currency note has certain common features such as the security thread consisting of black strips and the triangular IM (Identification mark) on an Rs. 100 note.

These characteristics of the original note help to differentiate them from a fake one. Hence, we use a method to detect the absence of one or all of these features by firstly converting the note into the BW scale.

#### 1) Storing Real Currency Note image into the FPGA:

- To feed the image of the real currency into Verilog, we need to convert it to binary (.coe file).
- The converted image from MATLAB is such that it has as many rows as the total number of pixels and the write depth is 1 (Binary number). So our 256 x 144p currency note image will have 36864 rows.
- Then a **Block Memory Module** is generated in the project which has as many addresses as the number of rows. So, in our case, it will have 36864 address bits.

This Memory module, like other modules, can be instantiated and used in the main module.



#### 2) Scanning and Reading the Test Case Currency notes:

- Uploaded the '.txt' file of the pre-processed note (using MATLAB) in the simulation sources of the Vivado project.
- Read the text file values into a **2-D array** of one-bit numbers using the "**\$readmemb**" function in Verilog.

#### 3) Security Features that we have compared:



- The triangular identification mark in the 100 rupee note.[7]
- The vertical Security Thread.[4]



**Real Currency Note** 



000000000

Fake Test Note - (a)
Absence of complete Security Thread



SIMULATION GRAPH

| Site Type             | 1   | Used  | 1   |   | - | Available |    |       | 1  |
|-----------------------|-----|-------|-----|---|---|-----------|----|-------|----|
| Slice LUTs*           | 1   | 10034 | 1   | 0 |   | 20800     |    | 48.24 | 1  |
| LUT as Logic          | 1   | 10034 | 1   | 0 | 1 | 20800     | 1  | 48.24 | 1  |
| LUT as Memory         | 1   | 0     | 1   | 0 | 1 | 9600      | 1  | 0.00  | 1  |
| Slice Registers       | 1   | 237   | 1   | 0 | 1 | 41600     | 1  | 0.57  | 1  |
| Register as Flip Flop | 1   | 204   | 1   | 0 | 1 | 41600     | 1  | 0.49  | J  |
| Register as Latch     | I   | 33    | I   | 0 | I | 41600     | 1  | 0.08  | 1  |
| F7 Muxes              | 1   | 0     | 1   | 0 | 1 | 16300     | 1  | 0.00  | 1  |
| F8 Muxes              | 1   | 0     | 1   | 0 | 1 | 8150      | 1  | 0.00  | 1  |
| ļ                     | -+- |       | -+- |   | + |           | +- |       | -+ |

**Real Currency Note** 

0000000



Fake Test Note - (b)
Absence of the Identification Mark (Triangle) & complete Security Thread



FPGA IMPLEMENTATION

| Ĺ | Site Type      | 1   | Used | ì   | Fixed | 1  | Available | ĺ. | Util% | ĺ. |
|---|----------------|-----|------|-----|-------|----|-----------|----|-------|----|
| + |                | -+- |      | -+  |       | -+ |           | -+ |       | -+ |
| 1 | Block RAM Tile | 1   | 1.5  | 1   | 0     | 1  | 50        | 1  | 3.00  | 1  |
| Î | RAMB36/FIFO*   | 1   | 1    | 1   | 0     | 1  | 50        | ľ  | 2.00  | ľ  |
| 1 | RAMB36E1 only  | 1   | 1    | 1   |       | 1  |           | I  |       | 1  |
| l | RAMB18         | 1   | 1    | J   | 0     | J  | 100       | L  | 1.00  | L  |
| 1 | RAMB18E1 only  | i   | 1    | 1   |       | 1  |           | Ī  |       | ľ  |
| + |                | -+- |      | -+- |       | -+ |           | -+ |       | -+ |

SYNTHESIS REPORT